// 笔试强训day23：城市群数量

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定，请勿修改，直接返回方法规定的值即可
     *
     * 
     * @param m int整型vector<vector<>> 
     * @return int整型
     */
    void makegroup(vector<bool>& able, vector<vector<int>>& m, int i)
    {
        int n = m.size();
        able[i] = false;
        for(int j = 0; j < n; j++)
        {
            if(m[i][j] == 1 && able[j])
                makegroup(able, m, j);
        }
    }

    int citys(vector<vector<int> >& m) {
        // write code here
        int n = m.size(), ans = 0;
        vector<bool> able(n, true);
        for(int i = 0; i < n; i++)
        {
            if(able[i])
            {
                makegroup(able, m, i);
                ans++;
            }
        }
        return ans;
    }
};